在实际开发工作中作为项目框架之一的Spring框架,相信我们经常会使用。然而在使用过程中,都会遇到很多的常见异常,本篇文章在这里总结一下,供大家参考借鉴。
Spring默认会将自身抛出的异常自动映射到合适的状态码,如下是一些示例:
1)项目404:找不到目标资源(可能路径问题)
2)项目400:前端发送到后台的参数类型,和所请求的路由方法参数不匹配,此时consle控制台没有出错
3)项目500:consle出错
1、找不到配置文件的异常
org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing XMLdocument from class path resource [com/yoodb/controller]; nested exception is java.io.FileNotFoundException:
class path resource [com/yoodb/controller] cannot be opened because it does not exist
含义:没有找配置文件为controller的xml,修改一下配置文件名字即可。
<init-param><param-name>contextConfigLocation</param-name>
<param-value>classpath:com/yoodb/config/testAjax.xml</param-value>
</init-param>
2、在xml中配置的命名空间找不到对应的Schema的异常
nested exception is org.xml.sax.SAXParseException: cvc-complex-type.2.4.c: The matching wildcard is strict,
but no declaration can be found for element 'util:list'.
xmlns:util="http://www.springframework.org/schema/util" 去掉,因为schema中不存在util命名
3、bean不是唯一的异常
org.springframework.beans.factory.NoUniqueBeanDefinitionException:No qualifying bean of type [com.yoodb.pojo.Person] is defined:
expected single matching bean but found 7: person0,person1,person2,person3,person4,person5,person6
at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBean(DefaultListableBeanFactory.java:313)
at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:985)
at com.yoodb.test.Test0.test1(Test0.java:35)
at com.yoodb.test.Test0.main(Test0.java:111)
这个异常是说,一个类配置了多个bean之后,我们还在使用ctx.getBean(Person.class);方法,即根据bean的类映射去获取bean对象。这个时候返回的bean对象不是唯一的,有多个bean对象。解决方法,就是根据bean的id去获取bean对象。
4、找不到jackson.jar的异常
StandardWrapper.Throwablejava.lang.NoClassDefFoundError: org/codehaus/jackson/JsonProcessingException
缺少jackson的jar包,导入jackson-all-1.9.5.jar即可
5、缺少日志jar包
java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactoryCaused by: java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory
这个问题是说,项目中缺少spring依赖的jar包文件。解决方法:加入commons-logging-1.1.3.jar即可。
6、找不到bean异常
org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'filter2' is defined这个问题是说,项目中找不到name为filter2的bean。说白了就是在applicationContext.xml中找不到id为filter2的bean,配置一下即可。
7、缺少spring-webmvc-4.1.6.RELEASE.jar包
严重: Error loading WebappClassLoadercontext: /Struts_Spring_Project
delegate: false
repositories:
/WEB-INF/classes/
----------> Parent Classloader:
org.apache.catalina.loader.StandardClassLoader@b33d0a
org.springframework.web.servlet.DispatcherServlet
java.lang.ClassNotFoundException: org.springframework.web.servlet.DispatcherServlet
解决方法:在项目中加入spring的mvc架包即可。如我的spring版本为4.0.6的,那么就把spring-webmvc-4.1.6.RELEASE.jar添加进去即可。
8、缺少spring-aop-4.1.6.RELEASE.jar包
java.lang.NoClassDefFoundError: org/springframework/aop/TargetSourcejava.lang.ClassNotFoundException: org.springframework.aop.TargetSource
解决方法:在项目中加入spring的aop架包即可。如我的spring版本为4.1.6的,那么就把spring-aop-4.1.6.RELEASE.jar添加进去即可。
9、缺少spring-expression-4.1.6.RELEASE.jar包
java.lang.NoClassDefFoundError: org/springframework/expression/ExpressionParserjava.lang.ClassNotFoundException: org.springframework.expression.ExpressionParser
解决方法:在项目中加入spring的expression架包即可。如我的spring版本为4.1.6的,那么就把spring-expression-4.1.6.RELEASE.jar添加进去即可。
10、bean的名字name或者id或者别名alias已经存在
org.springframework.beans.factory.parsing.BeanDefinitionParsingException:Configuration problem: Bean name 'a' is already used in this <beans> element
解决方法:把重复的名字改个名字即可。
11、bean的自动加载找不到相对应的bean问题
org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.yoodb] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}解决方法:在配置文件中的<beans>根节点下加default-autowire="byName" default-lazy-init="true"或者<context:component-scan base-package="com.xxx.dao.*"></context:component-scan>包下面用*匹配
12、spring事务超时transaction unexpectedly rolled back (maybe due to a timeout); nested exception is javax.transaction.RollbackException;
可能原因1:spring事务设置的时间比较短。
解决方法:把spring事务设置长一点,如果事务中有很多复杂的查询及更新操作,取消方法上的事务注解,然后把查询操作整理后放在方法最前面,把更新操作放在一块,用自定义事务把更新操作放进去。
可能原因2:可能是mysql数据库InnoDB使用缓冲池设置小了,事务隔离级别不对。
解决方法:把缓存mysql数据库InnoDB使用缓冲池设置大些,同时把事务隔离级别由默认的REPEATABLE_READ级别改为READ_COMMITTED(关于事务级别在这里不再描述);
可能原因3:查询、更新sql效率不高;
解决方法:加索引,注意根据不同的数据库编写不同的表及where条件顺序。